## **CLAIMS**

## What is claimed is:

- 1 1. A memory unitfor use in an integrated circuit (IC) comprising:
- 2 an array of memory cells;
- a first data transfer interface coupled to the array of memory cells to provide a
- 4 first access path for a selected one of a processor and a plurality of subsystems of
- 5 the IC to access said array of memory cells;
- a second data transfer interface coupled to the array of memory cells to
- 7 provide a second access path for said processor to access said array of memory
- 8 cells; and
- 9 a controller coupled to the array of memory cells and the first and second
- data transfer interfaces to control said array of memory cells and said first and
- 11 second data transfer interfaces to facilitate concurrent accesses of said memory unit
- 12 by said processor and said subsystems.
- 1 2. The memory unit of claim 1, wherein said first data transfer interface
- 2 comprises
- a first inbound queue coupled to said array of memory cells for queuing a first
- 4 plurality of memory accesses of said processor and said subsystem of a first priority;

9

10

11

| 5 | a second inbound queue coupled to said array of memory cells for queuing a    |
|---|-------------------------------------------------------------------------------|
| 6 | second plurality of memory accesses of said processor and said subsystem of a |
| 7 | second priority; and                                                          |

- an outbound queue coupled to said array of memory cells for queuing output responses to said first and second plurality of memory accesses of said processor and said subsystem of said first and second priorities accessed through said first and second inbound queues.
- The memory unit of claim 1, wherein said second data transfer interfacecomprises
- an inbound queue coupled to said array of memory cells for queuing a first
  plurality of memory accesses of said processor; and
- an outbound queue coupled to said array of memory cells for queuing output responses to said first plurality of memory accesses of said processor.
- 1 4. The memory unit of claim 1, wherein said controller comprises
- 2 a sequential storage structure coupled to said array of memory cells;
- 3 a multiplexor coupled to inbound queues of said first and second data transfer
- 4 units and said sequential storage structure to sequence memory accesses queued
- 5 in said inbound queues into said sequential storage structure; and

- a state machine coupled to said sequential storage structure, said multiplexor, and said inbound queues of said first and second data transfer units to control their operation.
- 1 5. The memory unit of claim 4, wherein said state machine controls said
- 2 multiplexor to sequence memory accesses queued in said second data transfer
- 3 interface into said sequential storage structure before sequencing any memory
- 4 access queued in said first data transfer interface into said sequential storage
- 5 structure.
- 1 6. The memory unit of claim 4, wherein said state machine controls said
- 2 multiplexor to sequence memory accesses queued in inbound queues of said first
- 3 data transfer interface into said sequential storage structure, in accordance with
- 4 assigned priorities of said inbound queues.
- 1 7. The memory unit of claim 1, wherein said controller comprises
- 2 a first sequential storage structure to stage headers for output responses to
- 3 memory accesses;
- 4 a second sequential storage structure coupled to said array of memory cells
- 5 to stage output responses to memory accesses;

| 6  | a first multiplexor coupled to said first and second sequential storage                |
|----|----------------------------------------------------------------------------------------|
| 7  | structures to selective output one of said staged headers of output responses to       |
| 8  | memory accesses and said staged output responses to memory accesses;                   |
| 9  | a second multiplexor coupled to said first multiplexor and outbound queues of          |
| 10 | said first and second data transfer units to selective output the selected output of   |
| 11 | said first multiplexor to a selected one of said outbound queues of said first and     |
| 12 | second data transfer unit; and                                                         |
| 13 | a state machine coupled to said first and second sequential storage                    |
| 14 | structures, said first and second multiplexors, and said outbound queues of said first |
| 15 | and second data transfer units to control their operation.                             |
|    |                                                                                        |
| 1  | 8. In a memory unit of an integrated circuit (IC), a method of operation               |
| 2  | comprising:                                                                            |
| 3  | queuing first memory accesses of a processor and a plurality of subsystems             |
| 4  | of the IC in inbound queues of a first data transfer interface;                        |
| 5  | queuing second memory accesses of the processor in an inbound queue of a               |
| 6  | second data transfer interface;                                                        |
| 7  | sequencing said first and second memory accesses into a single sequence of             |
| 8  | memory accesses; and                                                                   |
| 9  | servicing said first and second memory accesses in accordance with their               |
| 10 | sequence order.                                                                        |

- 1 9. The method of claim 8, wherein said queuing of said first memory accesses of
- 2 a processor and a plurality of subsystems of the IC in inbound queues of a first data
- 3 transfer interface comprises queuing said first memory accesses into inbound
- 4 queues of said first data transfer interface having associated priorities, in
- 5 accordance with priorities of said first memory accesses.
- 1 10. The method of claim 8, wherein said sequencing comprises sequencing
- 2 second memory accesses queued in said second data transfer interface before
- 3 sequencing any memory access queued in said first data transfer interface.
- 1 11. The method of claim 8, wherein said sequencing comprises sequencing first
- 2 memory accesses queued in inbound queues of said first data transfer interface, in
- 3 accordance with assigned priorities of the inbound queues.
- 1 12. The method of claim 8, wherein said servicing comprises generating and
- 2 queuing headers for output responses to said first and second memory accesses.
- 1 13. The method of claim 8, wherein said servicing comprises queuing output
- 2 responses to said first and second memory accesses.

- 1 14. The method of claim 8, wherein said servicing comprises merging headers for
- 2 output responses to said first and second memory accesses and output responses
- 3 to said first and second memory accesses.
- 1 15. The method of claim 8, wherein said servicing comprises selectively
- 2 outputting headers for output responses to said first and second memory accesses
- 3 and output responses to said first and second memory accesses to a selected one
- 4 of said first and said second data transfer interfaces.
- 1 16. An integrated circuit comprising:
- 2 a processor;
- 3 a plurality of subsystems; and
- 4 a memory unit coupled to said processor and said subsystems having at least
- 5 a first access path to facilitate access by a selected one of said processor and said
- 6 subsystem to access said memory unit and a second access path to facilitate
- 7 access by said processor.
- 1 17. The integrated circuit of claim 16, wherein said memory unit comprises
- 2 an array of memory cells;
- a first data transfer interface coupled to the array of memory cells to provide
- 4 said first access path for said selected one of said processor and said subsystems;

4

5

6

7

8

9

10

11

| 5 | a second data transfer interface coupled to the array of memory cells to |
|---|--------------------------------------------------------------------------|
| 6 | provide said second access path for said processor; and                  |

- a controller coupled to the array of memory cells and the first and second data transfer interfaces to control said array of memory cells and said first and second data transfer interfaces.
- 1 18. The integrated circuit of claim 17, wherein said first data transfer interface2 comprises
  - a first inbound queue coupled to said array of memory cells for queuing a first plurality of memory accesses of said processor and said subsystem of a first priority;
  - a second inbound queue coupled to said array of memory cells for queuing a second plurality of memory accesses of said processor and said subsystem of a second priority; and
  - an outbound queue coupled to said array of memory cells for queuing output responses to said first and second plurality of memory accesses of said processor and said subsystem of said first and second priorities accessed through said first and second inbound queues.
- 1 19. The integrated circuit of claim 17, wherein said second data transfer interface2 comprises
- an inbound queue coupled to said array of memory cells for queuing a first plurality of memory accesses of said processor; and

- an outbound queue coupled to said array of memory cells for queuing output responses to said first plurality of memory accesses of said processor.
- 1 20. The integrated circuit of claim 17, wherein said controller comprises
- 2 a sequential storage structure coupled to said array of memory cells;
- a multiplexor coupled to inbound gueues of said first and second data transfer
- 4 units and said sequential storage structure to sequence memory accesses queued
- 5 in said inbound queues into said sequential storage structure; and
- a state machine coupled to said sequential storage structure, said multiplexor,
- 7 and said inbound queues of said first and second data transfer units to control their
- 8 operation.
- 1 21. The integrated of claim 20, wherein said state machine controls said
- 2 multiplexor to sequence memory accesses queued in said second data transfer
- 3 interface into said sequential storage structure before sequencing any memory
- 4 access queued in said first data transfer interface into said sequential storage
- 5 structure.
- 1 22. The integrated circuit of claim 20, wherein said state machine controls said
- 2 multiplexor to sequence memory accesses queued in inbound queues of said first
- 3 data transfer interface into said sequential storage structure, in accordance with
- 4 assigned priorities of said inbound queues.

7

8

9

10

11

12

13

14

15

| 1 | 23. The integrated circuit of claim 17, wherein said controller comprises     |
|---|-------------------------------------------------------------------------------|
| 2 | a first sequential storage structure to stage headers for output responses to |
| 3 | memory accesses;                                                              |
| 4 | a second sequential storage structure coupled to said array of memory cells   |
| 5 | to stage output responses to memory accesses;                                 |

- a first multiplexor coupled to said first and second sequential storage structures to selective output one of said staged headers of output responses to memory accesses and said staged output responses to memory accesses;
- a second multiplexor coupled to said first multiplexor and outbound queues of said first and second data transfer units to selective output the selected output of said first multiplexor to a selected one of said outbound queues of said first and second data transfer unit; and
- a state machine coupled to said first and second sequential storage structures, said first and second multiplexors, and said outbound queues of said first and second data transfer units to control their operation.
- 1 24. The integrated circuit of claim 16, wherein said integrated circuit further
- 2 comprises an on-chip bus to which said memory unit and at least a subset of said
- 3 subsystems are attached.

- 1 25. The integrated circuit of claim 16, wherein said integrated circuit further
- 2 comprises a data traffic router to which said memory unit, said processor, and at
- 3 least one of said subsystems is attached, said data traffic router facilitating
- 4 concurrent communication between selected combinations of said memory unit, said
- 5 processor and said at least one subsystem.
- 1 26. The integrated circuit of claim 16, wherein each of said subsystems is a
- 2 selected one of a security engine, a voice processor, a collection of peripheral
- 3 device controllers, a framer processor, a network media access controller, and an
- 4 external device controller.
- 1 27. In an integrated circuit (IC), a method of operation comprising:
- 2 a processor and a plurality of subsystem of the IC successively making first
- 3 memory accesses of a memory unit of the IC via a first access path in turn;
- 4 the processor also successively making second memory accesses to said
- 5 memory unit via a second access path in parallel; and
- 6 the memory unit servicing said first and second memory accesses made
- 7 through said first and second access paths in parallel.
- 1 28. The method of claim 27, wherein said servicing comprises

memory unit;

- queuing said first memory accesses of said processor and said plurality of subsystems of the IC in inbound queues of a first data transfer interface of said
- queuing said second memory accesses of the processor in an inbound queue of a second data transfer interface of said memory unit;
- sequencing said first and second memory accesses into a single sequence of
  memory accesses; and
- 9 servicing said first and second memory accesses in accordance with their10 sequence order.
  - 1 29. The method of claim 28, wherein said queuing of said first memory accesses
- 2 of said processor and said plurality of subsystems of the IC in inbound queues of a
- 3 first data transfer interface comprises queuing said first memory accesses into
- 4 inbound queues of said first data transfer interface having associated priorities, in
- 5 accordance with priorities of said first memory accesses.
- 1 30. The method of claim 28, wherein said sequencing comprises sequencing
- 2 second memory accesses queued in said second data transfer interface before
- 3 sequencing any memory access queued in said first data transfer interface.

- 1 31. The method of claim 28, wherein said sequencing comprises sequencing first
- 2 memory accesses queued in inbound queues of said first data transfer interface, in
- 3 accordance with assigned priorities of the inbound gueues.
- 1 32. The method of claim 28, wherein said servicing comprises generating and
- 2 queuing headers for output responses to said first and second memory accesses.
- 1 33. The method of claim 28, wherein said servicing comprises queuing output
- 2 responses to said first and second memory accesses.
- 1 34. The method of claim 28, wherein said servicing comprises merging headers
- 2 for output responses to said first and second memory accesses and output
- 3 responses to said first and second memory accesses.
- 1 35. The method of claim 28, wherein said servicing comprises selectively
- 2 outputting headers for output responses to said first and second memory accesses
- 3 and output responses to said first and second memory accesses to a selected one
- 4 of said first and said second data transfer interfaces.
- 1 36. The method of claim 27, wherein the method further comprises
- a first of said subsystem notifying said processor with respect to said first
- 3 subsystem having placed a first data in said memory unit;

7

8

| 4 | said processor making a first access of said first subsystem, and awaiting for           |
|---|------------------------------------------------------------------------------------------|
| 5 | a first reply to said first access of said first subsystem; and                          |
| 6 | said processor making a second access of said memory unit via said second                |
| 7 | access path for said first data placed into said memory unit by said first subsystem     |
| 8 | after at least receiving said first reply for said first access of said first subsystem. |
|   |                                                                                          |
| 1 | 37. The method of claim 38, wherein the method further comprises                         |
| 2 | said processor making a second access of said memory unit via said first                 |
| 3 | access path, and awaiting for a second reply to said second access of said memory        |
| 4 | unit; and                                                                                |
| 5 | said processor making said first access of said memory unit via said second              |
| 6 | access path for said first data placed into said memory unit by said first subsystem     |
| 7 | after also receiving said second reply for said second access of said memory unit.       |
|   |                                                                                          |
| 1 | 38. The method of claim 27, wherein the method further comprises                         |
| 2 | a first of said subsystem notifying said processor with respect to said first            |
| 3 | subsystem having placed a first data in said memory unit;                                |
| 4 | said processor making a first access of said memory unit via said first access           |
| 5 | path, and awaiting for a first reply to said first access of said memory unit; and       |

access path for said first data placed into said memory unit by said first subsystem

after at least receiving said first reply for said first access of said memory unit.

said processor making a second access of said memory unit via said second